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(57) A secure and scalable system and method is 
described for carrying out database transactions over a 
network A transaction server on a network authenti- 
cates a user connected to the network with a client. The 
database access permission ot the user is determined, 
and the transaction server sends a graphical user inter- 
face that comports with the access permission of the 
user to the client. The transaction server receives a user 
database request from the client based upon inputs pro- 
vided by the user through the graphical user interface. 
The transaction server selects an action statement with 
formal parameters based upon the user database 
request. The action statement is evaluated by replacing 
its formal parameters with values from the user data- 
base request. The evaluated action statement is exe- 
cuted on a database, and the results are sent to the 
client, where they are displayed to the user through the 
graphical user interface. 
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Description 

BACKGROUND OF THE INVENTION 

5 The present invention relates to a system and method for secure and scalable database transactions over a net- 
work. 

Systems for mediating access to a database over a network are known. Generally, such systems consist of at least 
one client and a server both connected to the network. The server is connected to a database. The server can execute 
database server software (including a database search engine) and be connected to the database directly, or can be 
10 connected to the database through a database gateway and/or a database server. As used herein, a client is a compu- 
ter capable of a>mmunicating with a server over the network. A server is a computer capable of communicating with a 
client over the network. A computer includes a processor, computer readable memory, and a port to be connected to a 
network. A computer can further include other ports (ag., ports to be connected to input devices, output devices, and 
databases). 

is In some known systems, access to a database is restricted to a certain set of users. The information stored on the 
database may be proprietary, private, and/or secret. Moreover, it may be desirable to limit the access of these users to 
only some of the information stored on the database. For example, the access to a database containing retail product 
information may be restricted to retail merchants of the products. The access permitted each merchant can be further 
limited to the information relating to their own products, i.e., merchants cannot gain access to information relating to 

20 other merchants' products. In addition, functions and privileges available to a database administrator are not generally 
available to the merchants. 

A database can be accessed over a network such as a Local Area Network (LAN). A LAN typically supports a small 
number of clients at a given time. LANs are limited to a small number of clients because LAN applications typically 
require frequent and continuous communications between the clients and servers. These continuous communications 

25 between clients and servers on LAN networks enable both clients and servers to continually monitor each others* 
states. These systems are tightly coupled, i.e., the duration of a communication between a server and a client often 
lasts for the entire database session. Clients that communicate to a server for the entire duration of the database ses- 
. sion are known as "fat" clients. The hardware and software limitations of a given LAN will restrict the number of these 
fat clients that can access the database at a given time. Accordingly, systems for accessing databases over LANs scale 

30 poorly. Scalability is the capacity to substantially maintain or improve system performance as the number of system (or 
amount of system activity) users increases 

A database can also be accessed over a network of "thin" clients. In contrast to fat clients, which communicate to 
the server for the entire duration of the database session, a thin client communicates to the server only for a portion of 
the database session. An example of such a network is the World Wide Web. Usually, thin clients communicate to the 

35 server only for the duration of the database transaction. Thin clients advantageously require less hardware and soft- 
ware resources than fat clients. Accordingly, databases accessible on networks of thin clients are highly scalable. Net- 
works of thin clients are stateless. In a stateless network, the client and server are loosely coupled, i.e., they are only 
certain of each others* state when the client and server are actually communicating with each other. 

It is desirable to maximize the scalability of database applications on networks while securely restricting access to 

40 the database to authorized users. Known scalable methods of securely accessing a database over a network are typi- 
fied by those available on the World Wide Web on the Internet As shown in FIG. 1 , a client 10 and web server 1 1 are 
both coupled to a network 1 2. Web server 1 1 is coupled to a database server 1 3, which is connected to a database 1 4. 
In other known systems, the connections between the web server 1 1 and the database server 13 are through the net- 
work 12, or through a LAN. The blocks in FIG 1 that refer to the client 10, web server 1 1 , database server 13 and data- 

45 base 14 indicate software rather than hardware components. Thus, for example, the database server 13 and the web 
server 1 1 can be executed on a single computer. 

At the client's request a socket connection is formed between the client 10 and the web server 11. Client 10 and 
web server 1 1 each have an Internet Protocol (IP) address and a series of ports that are identified by a 16-bit value, 
known as the port number. A socket is the unique combination of port number and IP address A socket connection is 

so formed by a pair of sockets: one socket on the client 10 and one socket on the web server 11. Data is exchanged 
between client 10 and web server 1 1 through the socket connection. A standard socket connection is one that imple- 
ments standard ports tor particular-applications. Standard socket connections are descrtoed in J.K. Reynolds and J.B. 
Post el. Assigned Numbers. RFC 1060, March 1990. For example, TELNET, a standard protocol, uses port number 23. 
A nonstandard, or proprietary, socket connection is one that uses a port not associated with a standard application, or 

55 uses a standard port for a nonstandard application. 

Although the socket connection exists for the duration of the session, the client 10 and web server 1 1 only commu- 
nicate to each other for the time it takes to send a database request and receive the database results The client 1 0 and 
web server 1 1 are said to be loosely coupled. 
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To access the database server 13. the client 10 sends a database request to the web server 1 1 through the socket 
connection. The database request is a command to search or modify the information stored in the database 1 4. Exam- 
ples of database requests include conimands or procedures such as query, insert delete, or modify. The web server 1 1 
then interprets the database request submits the database request to the database server 13, which interacts with the 

5 database 14. Database server 1 3 sends the results to web server 1 1 , which then sends the database result to the client 
10 through the standard socket connection. 

In another known configuration, the user accessing the client 10 must first be identified and authenticated by the 
web server 1 1 before the information from the database server 1 4 can be accessed Typically, a user identifies herself 
by entering a unique user identification code into the client 10. The user identification code is sent from the client 10 

10 through the standard socket connection to the Web server 11. In one known authentication method, the user is authen- 
ticated by entering a password into the client 10. Each unique user identification code conesponds to a password. The 
password is either assigned to or selected by the user. The password is sent from the client 10 through the standard 
socket connection to the web server 11. H the password corresponds to the user identif ication code on web server 1 1 , 
then the user is allowed to access database 1 4 through web server 1 1 . 

is Known techniques for accessing a database over a network have several shortcomings. Without an authentication 
mechanism, a user can access the database 1 4 through the Web server 1 1 once the network address or location of the 
Web server 1 1 is known. On the World Wide Web, a network location is designated by its Uniform Resource Location 
(URL). Once the network location is known, the user need only establish a standard socket connection between the cli- 
ent 10 and the Web server 11. The socket connection can be established using widely-available network interfaces, 

20 such as browsers. Users can read, alter or delete information in database 1 4 without limitation, which can substantially 
degrade the quality of the database 14, and/or make it unavailable to other users. 

In a system that uses identification and authentication codes, the user must memorize her user identification code 
and password. Passwords are notoriously unsecure. Users often select simple passwords that are easy to remember. 
These passwords can be easily guessed by an unauthorized user. Further, users often forget their passwords, causing 

25 them to lose access to the database until the password can be replaced. The unique combination of a user identification 
code and password can be vulnerable to compromise. Users often record their user identification code and password 
in fixed form such as written media. Unauthorized users may gain access to the database by merely viewing the 
recorded user identification code and password. Once the user identification code and password are compromised, 
unauthorized users can access and compromise or damage the data stored in database 14. Further, access codes can 

30 be misappropriated by third parties monitoring the cornmunications between client 10 and web server 1 1 . 

Yet another disadvantage of known systems is that access to database 14 by authorized users can unmediated. 
Thus, even an authorized user can send commands to read, alter or delete data from database 14; these commands 
may be erroneous. Such erroneous commands can substantially damage the database 14. Access codes mediating 
access to the database 14 can be sent from client 10 to web server 1 1 , but these are subject to compromise. 

35 A further problem occurs when a user with authorization attempts to subvert the database 14, either by reading 
another user s private data, or altering or deleting data improperly For example, several competitors sharing a database 
14 may find it advantageous to learn about each others* businesses and alter the information relied upon by a compet- 
itor in making business decisions. A more secure system for accessing a database 14 would mediate access to the 
database even for authorized users. 

40 A superior system and method for accessing a database over a network would be scalable, and would protect the 
integrity and confidentiality of data stored in the database by securely mediating access to the database. The access 
controls would prevent unauthorized users from accessing the database and prevent authorized users from carrying out 
unauthorized database operations. This would be earned out in an environment that is easy to understand and use for 
the user, while maintaining a high level of system performance. 

45 

SUMMARY OF THE INVENTION 

In accordance with one embodiment of the present invention, a system is provided for securely accessing a data- 
base that includes a web server coupled to a client over a network, a transaction server coupled to the client over the 

so network, and a database server coupled to the transaction server. The client, executing instructions loaded on the client 
from the Web server, sends a request to the transaction server to establish a socket connection between the client and 
the transaction server. This can be a standard or nonstandard socket connection. The socket connection is established, 
and the transaction server advantageously implements security features that identify and authenticate the requesting 
user. Once the user is authenticated, the transaction server sends an appropriate graphical user interface (GUI) to the 

55 client through which the user sends and receives database transaction data (i.e., database requests and responses). 
The GUI is selected based upon the identity of the user. In one embodiment the GUI is dynamically generated. In 
another embodiment the GUI is selected from a predetermined set of GUIs. If the user is not authenticated, the socket 
connection is terminated, effectively refusing the unauthenticated user access to the database. Along with the GUI. the 
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transaction server generates and sends a session identification code that accompanies all further user database 
requests from the client 

The user interacts with the GUI to formulate a user database request with values, which is sent from the client to 
the transaction server over the socket connection. An example of user database request values is "SticWey" and "Super 
5 Parte II" in a request for the price of a product by manufacturer and product name. The database request from the client 
is sent using a simple messaging protocol, and advantageously need not be in a form executable by the database 
server (e.g., it need not be in SQL format). 

The transaction server receives the user database request and selects an action statement that corresponds to the 
request The action statement generally has parameters. For example, an action statement can be a parameterized 
10 statement that searches a database for the price a product made by X and named Y. X and Y are parameters in such 
an action statement A pseudo-code example of such a statement is: 
GET_PRICE:MANUFACTURER_NAME(X).PRODUCT_NAME(Y). 

The transaction server then evaluates the parameterized action statement by replacing the parameters with the 
user database request values. A pseudo-code example of an evaluated action statement is: 
is. GET_PRICE FOR MANUFACTURER_NAME(SticWey), 
PRODUCT_NAME(Super Parka II). 

The evaluated request, which is readable by a database server, is carried out on the database and a result is 
returned. In this way, the transaction server advantageously mediates access to the database, logically and securely 
separating the user and client from the database. The result of the database request from the database server is sent 
20 to the client 

In one embedment of the present invention, the transaction server verif ies the database results prior to transmitting 
the database request. 

In yet another embodiment, the security of the present invention is further enhanced by implementing access con- 
trols (e g., a user id and password system) between the transaction server and the database server. 
25 The present invention provides to a scalable user-friendly system with superior security features for accessing a 
database over a network. 

BRIEF DESCRIPTION OF THE DRAWINGS 

30 FIG 1 shows a known system for accessing a database over the World Wide Web. 

FIG 2 shows an embodiment of a transaction server in accordance with the present invention. 
FIG 3 shows an embodiment of a system in which the transaction server is employed in accordance with the 
present invention. 

FIG 4 is a flow chart representation of receiving and processing a client request for service in accordance with the 
35 present invention. 

FIG 5 is a flow chart representation of receiving and processing a user database request from an initialized user in 
accordance with the present invention. 

DETAILED DESCRIPTION 

40 

An embodiment of the apparatus in accordance with the present invention is shown in FIG 2, which shows a trans- 
action server 207. The transaction server 207 comprises a data bus 201 that connects a processor 202; computer read- 
able memory 203; a port 204 to be connected to a network; a port 205 to be connected to a database server 205; and 
a port 206 to be connected to computer readable storage device that includes action files 208. 

<5 Action files include action statements comprised of predefined database commands (e.g., queries, modifications, 
etc.) that have forma) parameters which are dynamically substituted with values supplied by a user. In the embodiment 
shown in FIG 2, the action files are stored on a peripheral memory device (e.g., a hard disk) at the transaction server. 
However, the action files can be stored at any location in accordance with the present invention, provided the action files 
are available to the transaction server. For example, the action files in one embodiment are stored on a database 

so accessed by the transaction server. In another embodiment the action files are stored on a server connected to the net- 
work. In this embodiment, the transaction server obtains action files through the port 204 that is connected to the net- 
work. 

An action file contains action statements, each of which has a unique label and a body. Trie label serves to uniquely 
identify a statement, and is generally a single line in length. In one embodiment the body of the action statement con- 
55 sists of several fines, but the last line of every statement ends with a line delimiter. Any ASCII character can be used as 
the line delimiter. In one embodiment the semi-colon symbol ";" is used as the delimiter. A position parameter, such as 
the "@" symbol, can be placed anywhere in the body of the statement. Each position parameter indicates a formal 
parameter whose value is typically supplied by a user before the statement is submitted to act on a database. 
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An example of an action statement that retrieves information is the following: 



20 



25 



35 



40 



45 



Get Orders information 
by Order Number. 
In parameters: 



1. Order Item Number 

2. EC USER n 



15 GET_0RDER_INFO : 

SELECT DISTINCT sc . sc_vjnerchant_order . tracking_number , 
ec . ec_v_user . user_name , 
sc.3c V merchant order. order date, 



TO CHAR(sc.sc_v_merchant_order .grand_total, ' 999 , 999 . 99 ■ ) , 
sc . sc_v_buyer . buyer_phone , 

LTRIM(RraiM(sc.sc_v_order_address.addres3_l) ) | | • 1 
| |LTRIM(RTRIM{sc.sc_v_order_addres3.address_2) ) | | * • 

| |LTRIM(RTRIM(sc. sc_v_order_address . address_3 ) ) | |CHR(10) 

| |LTRIM(RTRIM(sc.sc_v_order_address.city) ) | | ' , • 
| |LTTttM(RTRIM (sc. sc_v_order_address. state) ) j | ' ' 
| | LTRIM (RTRIM (sc. sc_v_order_address . postal_code) ) , 
sc . sc_vjnerchant_order . order_status_type_# 
FROM sc . sc_vjnerchant_order , 
sc . sc_v_ buyer , 
sc . sc_v_order_address , 
sc . sc_v_order_status_type , 
ec.ec_v_user, 
pa . pa_v_merchant 
WHERE s c. s c_v_me r chan t_order .merchant _order_# =» @ 

AND sc.sc_v_merchant_order .buyerj* = sc. sc_v_buyer .buyer_# 
AND sc.sc_v_buyer .ec_user_# = ec . ec_v_user . ec_user_# 
AND sc. sc_v_merchant_order.shipping_address_& = 
sc . sc_v_order_address . addr ess_# 

AND pa.pa_v_merchant.ec_user_#«e 

AND sc . sc_v_mercbant_order . merchant_#=pa . pa_v_merchant . merchant_# ; 



This parameterized action statement obtains order information from a database using an order number and an 
so electronic commerce user number. The label for this parameterized action statement is "GET_ORDERJNF0:" (the text 
preceding the label consists of comments.) The body of the action statement is listed after the label and ends with a ";" 
symbol. The two parameters (Order Item Number and EC_USER_#) are both represented by the "<§>" symbol. 

The transaction server receives a user database request (e.g.. a request for order information tor order no. 38475 
from a user with an electronic commerce user number 324), searches for the statement with the given label, retrieves 
55 the body of the statement, and evaluates the statement by replacing the parameters of the statement with the user data- 
base request values. The transaction server then passes the ready-to-execute statement to a database server. The 
database server carries out the statement, and sends the results (e.g., order information) to the transaction server. 
These results are sent from the transaction server to the client. 
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An example of an action statement that modifies a database is as follows: 



Assign a category 

Assign a stage — product_category for a produce in the 
stage_product_category table 

Uses the first stage_product_category row if the thesaurus_# is 
still NULL 

Creates a new stage_product_category row if an active one with a 
thesaurus_# already exists. 
In parameters : 

1. Stage product number 

2 . Thesaurus number 

3 . Ec user number 



SP_ASSIGN_CATS: 

st_pJcg_prod_category_merchant . add_assigned_j>roduct_category 
(®,©,®, :vl, :v2, :v3, :v4) ; 

20 



25 This parameterized action statement receives a request from a user with an electronic commerce user number (Ec 
user number) to assign a product category name (Thesaurus number) to a product (Stage product number.) In this 
example, the label for the stored procedure statement is "SP_ASSIGN_CATS:" Comments are included in the text 
before the label, and the body of the action statement occurs after the label. The three parameters (Ec user number, 
Thesaurus number and Stage product number) are each represented by the "@" symbol. 

30 In accordance with the present invention, a user with an electronic commerce user number sends a user database 
request from the client to the transaction server to assign a product category name to a product. For example, the user 
(with electronic commerce number 324) requests the product category "Jackets" be assigned to a product called the 
"Super Parka II." The transaction server selects the action statement above, and the three parameters in the action 
statement are replaced with the values in the user database request. 

35 The evaluated action statement is sent to the database server, which carries the statement out on the database. 
The results (e.g., indicating success or an error) are sent to the transaction server, which forwards a results message 
to the client. These results are displayed to the user through the GUI on the client. 

Another advantageous feature of the action statements in accordance with the present invention are action state- 
ment attrtoutes that can advantageously modify the behavior of the transaction server. A pseudo-code example of an 

40 action statement attribute is as follows: 

GET_PRICE:PRODUCT_NAME(X),MODEL_NUMBER(Y),FORMAT(X,Y,PRICE 
),SEARCH_MODEL_NUMBER(X,?),STDRE_QUERY_HISTORY(X, Y.PRICE). 

This action statement has three attributes. The first, FORMAT(X, Y.PRICE) specifies that the results should be pre- 
sented to the user in accordance with a predetermined format with the product name first, then the model number, and 

as finally the price. The second attribute, SE ARCH_MODEL_NUMBE R(X, 7) invokes another action statement that search 
for the model numbers for a given product name if the model number is not submitted by the user, and returns a list of 
the model numbers to the user. The user can then advantageously select a desired model number. The third attribute. 
STORE_QUERY_HISTORY(PRICE,X,Y) stores the price, product name and model number in a query history file that 
is used to determine system performance and the identity of the most requested items of information. This is useful in 

so making caching decisions, for example. These three examples of action statement attributes (a format attribute, a 
pointer to another action statement, and a store attribute) illustrate the utility of such attributes. 

Attributes can be used to modify the behavior of the transaction server, database gateway, database drivers or 
database server in any useful way. A database gateway is an interface between the transaction server and a database 
server. For example, attributes can link an action statement to a particular database, modify the type of connection 

55 between the transaction server and database server, or specify additional security measures to be taken when the eval- 
uated action statement is carried out 

The transaction server uses the action files to advantageously logically separate a user from a database This 
allows the user to access one or more databases through an easy-to-use GUI without having to learn or understand 
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database commands or languages. A user submits a database request through an easy-to-use graphical user interface 
(GUI) at a client. The values provided by the user through the client database request are substituted into appropriately 
selected action files understandable by a database server and carried out The results are sent to the cfient for presen- 
tation to the user through the GUI. 
5 Another advantage of logically separating the user from the database is enhanced security. By preventing the user 
from directly accessing the database, the confidentiality and integrity of the database can be advantageously control- 
led. 

Yet another advantage of using a transaction server and action fBes in accordance with the present invention is flex- 
ibility. The action files can be changed and tailored to specific databases and database commands and languages 

io transparently to the user. Thus, changes in database hardware and software do not incur any expense whatever to the 
user, who need not learn new ways to access needed data 

An embodiment of a system in accordance with the present invention is shown in Fig. 3. Client 301 and transaction 
server 302 are connected to network 303. The transaction server 302 is coupled to a database server 304, which is in 
turn coupled to a database 305. In another embodiment (not shown) transaction server is connected to database server 

is 304 (which is in turn connected to database 305) through network 303. In yet another embodiment of the present inven- 
tion, no separate database server 304 is employed. Rather, the transaction server 302 executes a software program 
that enables the transaction server 302 itself to interact directly with the database 305 (e.g., cany out queries and mod- 
ifications on the database) without the need for a separate database server 304. The boxes representing the client 301 , 
transaction server 302, database server 304 and database 305 refer to the software rather than the hardware needed 

20 to carry out the functions of each. Thus, for example, transaction server 302 and database server 304 can be carried 
out on the same computer. 

The system shown in FIG 3 operates in accordance with the method of the present invention shown in FIGs 4 and 
5. FIG 4 a procedure in accordance with the present invention that takes place when the client sends a request to the 
transaction server to establishes a socket connection. FIG 5 shows a method in accordance with the present invention 
25 whereby once a session is initialized, the transaction server receives and processes a session user database request. 

In step 401 of FIG 4. a socket connection is established between the client and the transaction server at the client's 
request Client software is obtained and loaded on the client in order to enable the client to interact with the transaction 
server. 

In one embodiment, a user 306 (FIG 3) obtains the client software through known distribution methods (e.g., on 

30 computer readable memory through the Postal Service, on computer bulletin boards, etc.) and installs it on the client 
301 . In another embodiment, the user obtains the software from a server (not shown) connected to the network 303 
(eg., via file transfer protocol (FTP)). In yet another embodiment, the user obtains the client software by executing a 
known hypertext browser (such as the Netscape Navigator from the Netscape Communications Company, the Internet 
Explorer from the Microsoft Company of Washington, etc.), and retrieving a hypertext page from the transaction server. 

35 The hypertext page from the transaction server includes Java applet that enables the user to establish a socket connec- 
tion between the client and the transaction server. Thus, the transaction software can be a stand-alone program, plug- 
ins designed to operate in conjunction with a known browser, a Java applet associated with a hypertext file obtained 
from the transaction server (302 in FIG 3), or any other executable software program. 

Next, the transaction server attempts to authenticate the user in step 402. A user is authenticated when the identity 

40 of the user and the user's permission to access the transaction server are verified. Authentication data can be carried 
between the client and transaction server using a simple messaging protocol. An embodiment of a simple messaging 
protocol in accordance with the present invention is described below. If the user cannot be authenticated, the socket 
connection is terminated by the transaction server 403. If the user is authenticated, the transaction server consults a 
cache table to determine H the user has already been assigned a session identification code 408. If the user has already 

45 been assigned a session identification code, the present request is part of a user session that has already been initial- 
ized. In this case, the method shown in FIG 5 is next followed 407, starting with step 501. 

If the user has not yet been assigned a session identification code, then the transaction server carries out the ses- 
sion initialization procedure shown in steps 404, 405 and 406. In step 404. the transaction server verifies the user's 
database access permissions. 

50 Verifying the database access permissions of an authenticated user is carried out in one embodiment of the 
present invention when the transaction server consults database access permission stored in a table cross-indexed 
with the user's user id. In one embodiment, the access permission indicates the type of user (e.g., merchant system 
administrator, etc.) Each user type is associated with certain predetermined database access permissions. For exam- 
ple, a user of type "merchant" is allowed only to read certain records such as historical records (sales trends) and 

55 records pertaining to manufacturers price lists. The merchant user is allowed to both read and modify records pertain- 
ing to his own inventory (e.g., change merchandise descriptions, record sales, orders, etc.) On the other hand, a user 
of type "administrator" is allowed to read and modify system administration records, but is not allowed to read or modify 
merchant records. 
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In another embodiment of the present invention, the database access permission for each user indicates the types 
of actions that user is allowed to take with respect to the database. Such permission indicates record or types of record 
and the action with respect to each that the user may take (eg., read, modify, etc.) In this way. the present invention 
advantageously mediates access to a database by users, enhancing system security. 

5 Once the access permissions of an authenticated user are verified, the transaction server sends an appropriate 
GUI to the user's client 405. In one embodiment of the present invention, the GUI is dynamically generated. In another 
embodiment, the GUI is selected from a predetermined set of GUIs. The GUI sent to the user is said to "comport" with 
the user's database access permission when the GUI provides an interface that only allows user to formulate user data- 
base requests within the scope of the user's database access permission. Thus, for example, a user who is authorized 

w to read historical sales data and read and modify order information, but who is unauthorized to read or modify system 
administration data is provided with a GUI having known GUI features (buttons, text boxes, icons, etc.) that support only 
the user's authorized access. In this case, the user is able to read historical sales data using a combination of buttons 
and pull down menus, and read and modify order information using a combination of buttons and text boxes. However, 
there is no provision in the user's GUI for reading or modifying system administration data. In this way, the present 

is invention advantageously enforces a user's access permissions simply and economically. 

The transaction server also generates and sends a session identification code to the client 406. The session iden- 
tification code is con elated with the identity of the user (eg., the user id) at the transaction server, and is used to identify 
data exchanged between the transaction server and the client for the rest of the session. In one embodiment of the 
present invention, the session identification code is the same as the user id. A session is defined as the period of activity 

20 from the time the session identification code is sent to the client until the time the client terminates the session through 
the GUI. or the user loses authentication, or the socket connection is unexpectedly terminated, or any other event 
occurs that requires the user to be newly authenticated and a new GUI and/or session identification code be sent to the 
client. Once the steps in FIG 4 have been completed, the session initialization procedure is complete and the user can 
send database requests from the client to the transaction server, which are processed in accordance with the method 

25 shown in FIG 5. 

After receiving the session identification code during the session initialization process, the client sends the code 
with every user database request to the transaction server, the session identification code advantageously allows the 
transaction server to keep track of data to and from each client even in a stateless environment such as the Internet. 
FIG 5 shows a method in accordance with the present invention whereby the transaction server processes a user 

30 database request. In step 50 1 . a user database request is received at the transaction server from the client. An example 
of a user database request is a request for ordering information for a product (i.e., the number of units of a given product 
ordered during a certain period of time) submitted by a user through a GUI on a client 

The database request is sent using a simple messaging protocol. One embodiment of the simple messaging pro- 
tocol consists of a finite number of tokens separated by delimiters and ending in a message delimiter. In the present 

35 embodiment there are N tokens, where N is an integer equal to the number of positioned parameters in the statement 
plus three. The generic format of a database request of N tokens is as follows: (token 1 )<dlm>(token 2) (dim). . . (token 
N ). Here, "(dim)" represents the token delimiter. Any ASCII character or combination of ASCII characters can be used 
for the token delimiter, but it is important that the character of combination thereof not inadvertently activate, modify, or 
interfere with the actual or intended meaning of a database request. A prefened- embodiment uses an uncommon char- 

40 acter or combination for the delimiter. For example, one prefened embodiment uses the ASCII character that signif ies 
a "registered trademark", i.e., "®" is used as a token delimiter. 

The simple messaging protocol can be used to authenticate the client Before the client is authenticated, the first 
token value of a message has a value of zero. Messages whose first tokens are zero carry information needed to 
authenticate the client to the transaction server. After the client's identity and privilege to access the transaction server 

45 are verified, the first token of each message from the client to the transaction server has the value of the session iden- 
tification code. The second position parameter, (token 2), is a boolean flag to indicate the type of statement. In one 
embodiment, a backslash V character indicates that the statement is a stored procedure command and a null character 
indicates that the statement is a SQL command. The third token, "(token 3)". is the unique label of the statement. Sub- 
sequent tokens are positioned parameters for the corresponding statement. The number of the these tokens should 

so match the number of positioned variables in a statement 

An example of a database request in accordance with the present invention is: ;merchant1234®V® topsel- 
ler® 10® 1996V The session identif ication code is "merchant 1234". The token delimiter, the registered trademark sym- 
bol, separates the first token from the second token. The second token, the backslash, indicates that the database 
request is a stored procedure request. The third token, loosen er". indicates the label of the statement. The fourth and 

55 f ifth tokens are positioned parameters that are variables in the statement The scored procedure "topseHer" may search 
the database for a merchants top selling products in a given year. The fourth token may indicate how many of the top 
selling products will be displayed. The fifth token may indicate the year. In the instant example, the database request 
asks the transaction server to return the top ten setters in 1996. 
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In step 502. the transaction server parses the database request and identifies the action statement corresponding 
to the user database request In this embodiment, the first token, the session identification code, identifies the client 
submitting the request and the session. The second token, the boolean action file flag, identifies the type of action file 
thai is to be accessed. The third token, the statement label, identifies the action statement (from the appropriate action 

5 file) that corresponds to the user database request In step 503. the transaction server evaluates the selected action 
statement by replacing parameters in the action statement with values from the user database request. 

In step 504. the evaluated action statement is carried out on the database. In step 505, a message is sent from the 
transaction server to the client indicating the results of carrying out the evaluated action statement on the database 
(e.g.. query results, modification results, error codes, etc.) The message includes appropriate GUI control signals thai 

w cause the GUI at the client to display these results to the user. 

In one embodiment of the present invention, an additional layer of security is interposed between the transaction 
server and the database using database access codes (e.g.. database user ids and passwords). Such access codes 
are internal to the transaction server, and are advantageously invisible and inaccessible to users, thus enhancing their 
security. Each database access code (e.g., user id and corresponding password) has a corresponding access permis- 

is sion. For example, when the transaction server logs in to the database server with a user id and password, the database 
server will only carry out evaluated action statements that comport with the access permission associated with that user 
id and password. This advantageously provides another security feature between the database and users. The user id 
and password selected by the transaction server for an evaluated action statement is based upon the access permis- 
sion of the user making the corresponding database request For example, when the transaction server has evaluated 

20 an action statement based upon a database request from a merchant the transaction server selects the user id "mer- 
chant" and the corresponding password "b832rf" to log in to the database. The database access permission cone- 
sponcfing to "merchant" and "b832rf" matches the access permission of a user identified as a merchant, determined in 
step 404 of FIG 4. The use of database access codes further enhances the security of the present invention. For exam- 
ple, H a user were able to circumvent the controls imposed by the user's GUI and submit a database request to modify 

25 a record in an unauthorized fashion, the database user id and password system would prevent such unauthorized mod- 
ification. 

In step 506, the socket connection is closed between the client and the transaction server. 
Due to the stateless network environment in which the present invention operates, each user request for service 
must be analyzed to determine if it is part of a session that has already been initiated, or if a new session has to be 

30 started (e.g.. as shown in FIG 4). This process is shown in FIG 6. A socket connection is established at the user s 
request 601 . rf the transaction server cannot authenticate the user, then the socket connection is terminated 602. If the 
transaction server authenticates the user, then the transaction server searches a cache table for the user and a corre- 
sponcfing session identification code 603. If no session identification code is found, then the initialization process shown 
in FIG 4 is carried out 604 starting with step 404. If a session identification code is found, then the database request 

35 process shown in FIG 5 is carried out 605 starting with step 501 . 

This stateless mode of communication between the client and the transaction server advantageously allows the 
present invention to scale well, targe numbers of users are easily accommodated by the present invention by maintain- 
ing a connection only for the duration of a single database request and reporting of the results. This minimizes the bur- 
den placed on the transaction server and database server by each user. The present invention is thus more 

ao advantageously efficient than known, less scalable systems that maintain an open connection between a client and 
server during several database requests. 

When the client software is implemented on the client as a Java applet embedded in an HTMt f 3e. the applet has 
two major threads. The first thread processes input from the user, and the second thread communicates with the trans- 
action server. The second thread sends database requests to the transaction server in accordance with the simple 

45 messaging protocol, and monitors responses from the transaction server. The applet on the client also verifies every 
user input for possible enors before initiating a new transaction with the transaction server, advantageously preventing 
the transaction server from being unnecessarily burdened by being asked to process an erroneous user request. For 
example, user request with a date range input by a user where the year is outside a predetermined range (e.g., outside 
the range 1 980-1998) is checked and rejected by the client software, which does not open a socket connection with the 

so transaction server until an acceptable date is input by the user. 

The use of action files advantageously logically separates the client transaction software from the database 
schema. By moc&fying the contents of the action file, it is possfole to customize the functionality of the transaction soft- 
ware without having to change the transaction software. A user executing a transaction software Java applet on the cli- 
ent need not understand the structure of the database, the SQL language, or the names of stored procedures and their 

55 parameters. Afl database queries are carried out by the database server based upon instructions derived from the 
action f Bes selected by the transaction server to carry out a validated database request from an authenticated client. 
This advantageously provides both flexibility and security in carrying out database queries from clients. In known sys- 
tems, security is typically provided at the expense of functionality, performance and/or f lexfoility. The present invention 
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advantageously provides security with enhanced functionality, performance and flexibility. 

Security is provided in accordance with the present invention by authenticating. (Le.. verifying the identity and 
access permissions of) a user and/or client, and logically separating the transaction software used by the client to inter- 
act with the database from the database itself. Enhanced functionality, performance and flexibility are provided in 
5 accordance with the present invention by the ease with which system functionality and performance can be tailored to 
meet the needs of a particular client or environment by changing the contents of the action ffles. The action files can 
advantageously be changed without requiring any changes to the transaction software implemented on the client Like- 
wise, the action files, being substantially independent from the database server, can be easily modified to accommo- 
date different database server languages, protocols, and platforms. This can be advantageously carried economically 
jo and easily without having to modify the software of the transaction server. 

The flexibility of the present invention is further enhanced because the user need not learn nor understand complex 
database languages to access the database. An easy-to-use GUI that can be tailored to the meet the needs of an indi- 
vidual user is provided to the client from a web server or from a transaction server that includes web server functionality. 

The present invention is advantageously scalable because it operates in a stateless environment establishing a 
15 separate socket connection for each user database request. This makes the most efficient use of the transaction and 
database servers, and enables the system in accordance with the present invention to efficiently process requests from 
a large body of users. 

The present invention provides an efficient, secure, flexible and scalable way to provide database services to users 
on a network. 

20 Where technical features mentioned in any claim are followed by reference signs, those reference signs have been 
included for the sole purpose of increasing the intelligibility of the claims and accordingly, such reference signs do not 
have any limiting effect on the scope of each element identified by way of example by such reference signs. 

Claims 

25 

1 . A secure and scalable system for carrying out database transactions for a user with a client connected to a network, 
comprising a transaction server with an action file containing an action statement said transaction server con- 
nected to the network, a database server connected to the transaction server, and a database connected to the 
database server, wherein said transaction server authenticates a user, determines the database access permis- 

30 sion of the user, sends a graphical user interface that comports with the database access permission of the user to 
the user's client, receives a user database request with values provided by the user through the graphical user 
. interface on the user's client, selects and evaluates an action statement corresponding to the user database 
request and sends said action statement to said database server, and wherein said database server carries out 
said evaluated action statement on said database and sends the results to said transaction server, and wherein 

35 said transaction server sends a message indicating the results to the client and the results are displayed to the user 
on said graphical user interface. 

2. The system of claim 1, wherein said evaluated action statement is sent to said database server with a database 
access code having a corresponding database access permission equivalent to the database access permission 

40 of the user, said database server carrying out said evaluated action statement on said database only if said evalu- 
ated action statement comports with said database access permission corresponding to said database access 
coda 

3. A scalable method for carrying out secure database transactions over a network socket connection for a user with 
45 a client connected to the network, comprising the steps of: 

a authenticating the user; 

b. determining the database access permission of the user; 

c. serxfing a graphical user interface that comports with the database access permission of the user to the cli- 
so ent; 

d. receiving a user database request containing user values from the client; 

a selecting an action statement from an action file based upon the user database request; 
1 evaluating the selected action statement using user values; 
g. using the evaluated action statement to carry out a database action; 
55 h. receiving the results of the database action; and 

I sending results of the database action to the client 

4. The method of claim 3. wherein using the evaluated action statement to cany out a database action comprises the 
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steps of: 

a. sending the evaluated action statement with a database access code to a database server, the database 
access code determining a database access permission that is equivalent to the database access permission 
of the user; 

b. carrying out the evaluated action statement on the database with the database server H the evaluated action 
statement ts permitted by the database access permission determined by the database code; and 

c. sending an enor message from the database server to the transaction server H the evaluated action state- 
ment is not permitted by the database access permission determined by the database coda 

A transaction server that provides secure database transactions to users over a network, comprising a processor, 
computer readable memory, a port to be connected to a network, a port to be connected to a database and an 
action file containing an action statement that is selected and evaluated by said transaction server in response to 
a database request received from a client with a user. 

The transaction server of claim 5, wherein said action file is stored in said computer readable memory; or 

further comprising a port to be connected to an external computer readable memory device that stores said 
action fBe; or 

wherein said transaction server authenticates a user and determines the database access permission of the 
user; or 

wherein said transaction server sends to the client a graphical user interface that comports. with the data- 
base access permission of the user; or 

wherein said evaluated action statement is executed on said database and said transaction server sends 
results of the executed action statement to the user. 

The transaction server of claim 5, wherein said action statement comprises a command to retrieve or modify data 
stored in said database. 

The transaction server of claim 7, wherein said action statement further comprises a formal parameter that is 
replaced by a value supplied by a user, evaluating said action statement; or 

wherein said action statement further comprises an attribute that modifies the behavior of the transaction 

server. 

9. A scalable method for carrying out secure database transactions for an authenticated user with a client through a 
35 network socket connection between a transaction server and the user's client, comprising the steps of: 

a. selecting an action statement based upon a user database request containing values received at the trans- 
action server from the client; 

b. evaluating the action statement using the values contained in the user database request; and 
40 c. carrying out the evaluated action statement on a database. 

1 0. The method of claim 9, further comprising the steps of determining the database access permission of the user and 
sencfing to the client a graphical user interface that comports with; the database access permission of the user; 
and/or 

45 further comprising the step of sending the results of executing the evaluated action statement on the data- 

base to the client. 

1 1 . The method of claims 9 or 10. wherein the selected action statement contains formal parameters and the selected 
action statement is evaluated when values contained in the user database request replace formal parameters of 

so the selected action statement; and/or 

wherein the selected action statement is a database query; and/or 
wherein the selected action statement is a database modifier. 

1 2. The method of one or more of daim 9-1 1 , wherein carrying out the evaluated action statement on a database com- 
55 prises the steps of : 

a. sending the evaluated action statement with a database access code to a database server, the database 
access code determining a database access permission that is equivalent to the access permission of the 
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user; 

b. carrying out the evaluated action statement on the database with the database server if the evaluated action 
statement is permitted by the database access permission determined by the database code; and 

c. sending an error message from the database server to the transaction server rf the evaluated action state- 
5 mem is not permitted by the database access permission determined by the database coda 

1 3. A transaction server with computer readable medium for carrying out secure database transactions for an authen- 
ticated user through a network socket connection between said transaction server and a client of the user, said 
computer readable medium having a computer program encoded thereon, comprising: 

10 

a. a first portion of said mecfium having a first program segment for selecting an action statement containing 
formal parameters based upon a user database request containing values received at the transaction server 
from the dient; 

b. a second portion of said medium having a second program segment for evaluating the action statement by 
is replacing formal parameters contained in the action statement with values contained in the user database 

request; and 

c. a third portion of said medium having a third program segment executing the evaluated action statement on 
a database. 

20 14. The transaction server of claim 1 3, further comprising a fourth portion of said medium having a fourth program seg- 
ment for determining the database access permission of a user and sending a graphical user interface that com- 
ports with the database access permission of the user from the transaction server to the client; or 

further comprising a fourth portion of said medium having a fourth program segment for sending the results 
of carrying out the evaluated action statement on the database to the client. 

25 

1 5. A scalable system for carrying out secure database transactions for a authenticated user connected through a cli- 
ent to a network, comprising: 

a. means for authenticating the user; 
30 b. means for selecting and evaluating an action statement using a user database request; 

c. a database; 

d. means for executing an evaluated action statement on said database; 

e. means for sending the results of executing the action statement on the database to the client. 

35 16. The system of claim 1 5, further comprising means for determining the database access permission of a user and 
sending a graphical user interface that comports with the database access permission of the user to the client. 
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